/* TimeType.java
 *
 * Copyright 2006, Tim Dwelle.
 *
 * Licensed under the Apache License, Version 2.0 (the
 * "License"); you may not use this file except in
 * compliance with the License.  You may obtain a copy of
 * the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in
 * writing, software distributed under the License is
 * distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR
 * CONDITIONS OF ANY KIND, either express or implied.  See
 * the License for the specific language governing
 * permissions and limitations under the License.
 *
 */

package dowry.hibernate;

import java.text.*;
import java.util.*;
import org.hibernate.mapping.Property;
import dowry.*;

/**
 * Object representation of a Time datatype.
 *
 */
public class TimeType
    extends dowry.datatype.TimeType
    implements HibernateType
{
    /**
     * Generates a map of attributes for the specified
     * Hibernate property, based on the rules of this
     * datatype.
     *
     * @param entityMapper  a handle back to the entity
     *                      mapper processing the Hibernate
     *                      configuration
     *
     * @param property      the Hibernate property
     *
     * @return              a Map containing the relevant
     *                      Dowry attributes
     *
     */
    public Map toConfiguration(HibernateEntityMapper entityMapper,
                               Property property)
    {
        Map cfg = new HashMap();

        String propertyType = entityMapper.getPropertyType(property);
        cfg.put(JAVA_CLASS, propertyType);
        cfg.put(TYPE, entityMapper.toType(propertyType));
        cfg.put(REQUIRED, new Boolean(!property.isOptional()));

        return cfg;
    }
}